package com.qf.utils;

import com.qf.bean.Orders;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import java.io.IOException;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.List;

/**
 * 2019/11/22
 * 郭程鹏
 * gcp1909
 * 面向代码面向君,不负时光不负卿
 */

public class ExcelUtilz {
        //1、创建一个excle文件
         static HSSFWorkbook hssfWorkbook;
         //2、创建文件中的sheet表，参数是sheet名称
         static HSSFSheet sheet;
         //创建名，创建表的第一行
        public static void createFirstRow(String sheetName){
            hssfWorkbook=new HSSFWorkbook();
            sheet=hssfWorkbook.createSheet(sheetName);
            //创建第一行的字段名
            HSSFRow row = sheet.createRow(0);
            String[] heads={"编号","机构名称","联系人","预约时间","操作人","预约状态","操作日期"};
            for (int i = 0; i < heads.length; i++) {
                //创建列
                HSSFCell cell = row.createCell(i);
                //每一列的值
                cell.setCellValue(heads[i]);
            }
        }

        //3、循环创建其他行的值 导出数据
    public static void createSheetValue(List<Orders> orders){

        //向这个表中的其他行赋值
        for (int i = 0; i < orders.size(); i++) {
            //创建第二行及以后
            HSSFRow row = sheet.createRow(i + 1);
            //当前行的值
            Orders order = orders.get(i);
            //向第二行及以后的每一列中赋值

            //第二行第一列
            HSSFCell cell1 = row.createCell(0);
            cell1.setCellValue(order.getProId());
            //第二行第二列
            HSSFCell cell3 = row.createCell(1);
            cell3.setCellValue(order.getInsName());
            //第二行第四列
            HSSFCell cell4 = row.createCell(2);
            cell4.setCellValue(order.getUserName());
            //第二行第五列
            HSSFCell cell5 = row.createCell(3);
//            时间转换格式
            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
            String format1 = format.format(order.getOrderDate());
            cell5.setCellValue(format1);
            //第二行第六列
            HSSFCell cell6 = row.createCell(4);
            cell6.setCellValue(order.getServerUser());
            //第二行第七列
            HSSFCell cell7 = row.createCell(5);
            cell7.setCellValue(order.getOrderState());
            //第二行第八列
            //            时间转换
            HSSFCell cell8 = row.createCell(6);
            String format2 = format.format(order.getOrderDate());
            cell8.setCellValue(format2);

        }
    }

    //excle输出 字节输出
    public static void export(OutputStream outputStream) throws IOException {

        //以网格的格式输出
        sheet.setGridsPrinted(true);
        //创建一个文件
        //以字节流响应给用户
        hssfWorkbook.write(outputStream);
        outputStream.flush();
    }


}
